#include <cstdio>
#include <string>
#include <vector>
#include <cstring> 
#include <iostream>
#include <algorithm>
using namespace std;
typedef long long ll;
const int maxv=1000086;
// http://codeforces.com/contest/102
// Clothes
vector<int> mat[127];
int prc[127]={0};
int minp[127]={0};
 
int main()
{
	memset(minp,-1,sizeof minp);
	int n,m,ans=3*maxv;	cin>>n>>m;
	for(int i=0;i<n;i++)
	{
		scanf("%d",&prc[i+1]);
		mat[i].clear();
		minp[i]=-1;
	}
	for(int i=0;i<m;i++)
	{
		//cout<<ans<<endl;
		int a,b;
		scanf("%d%d",&a,&b);
		for(int i=0;i<mat[b].size();i++)
		{
			int k=mat[b][i];
			for(int j=0;j<mat[k].size();j++)
			{
				if(mat[k][j]==a) ans=min(prc[a]+prc[b]+prc[k],ans);
			}
		}
		mat[a].push_back(b);
		mat[b].push_back(a);
	}
//		minp[a]=(minp[a]+1)?min(minp[a],prc[b]):prc[b];
//		minp[b]=(minp[b]+1)?min(minp[b],prc[a]):prc[a];
	if(ans==3*maxv) cout<<"-1";
	else cout<<ans;
	return 0;
} 